150B - Quantity of Strings - CodeForces Solution


combinatorics dfs and similar graphs math *1600

Please click on ads to support us..

C++ Code:

#include<bits/stdc++.h>
using namespace std;
int n,m,k,p,a[2005],num;
long long ans=1,mod=1e9+7;
int A(int x){
	if(x==a[x])return x;
	a[x]=A(a[x]);
	return a[x];
}
int main(){
	cin>>n>>m>>k;
	num=n;
	for(int i=1;i<=n;i++)a[i]=i;
	for(int i=1;i<=n-k+1;i++){
		for(int I=i,J=i+k-1;I<J;I++,J--){
			if(A(I)!=A(J))num--;
			a[a[I]]=A(J);
		}
	}
	for(int i=1;i<=num;i++)ans*=m,ans%=mod;
	cout<<ans;
  	return 0;
}
 		 		  		   	  	  				  	  			


Comments

Submit
0 Comments
More Questions

Char Sum
Two Strings
Anagrams
Prime Number
Lexical Sorting Reloaded
1514A - Perfectly Imperfect Array
580A- Kefa and First Steps
1472B- Fair Division
996A - Hit the Lottery
MSNSADM1 Football
MATCHES Playing with Matches
HRDSEQ Hard Sequence
DRCHEF Doctor Chef
559. Maximum Depth of N-ary Tree
821. Shortest Distance to a Character
1441. Build an Array With Stack Operations
1356. Sort Integers by The Number of 1 Bits
922. Sort Array By Parity II
344. Reverse String
1047. Remove All Adjacent Duplicates In String
977. Squares of a Sorted Array
852. Peak Index in a Mountain Array
461. Hamming Distance
1748. Sum of Unique Elements
897. Increasing Order Search Tree
905. Sort Array By Parity
1351. Count Negative Numbers in a Sorted Matrix
617. Merge Two Binary Trees
1450. Number of Students Doing Homework at a Given Time
700. Search in a Binary Search Tree